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Application No. 09/979,572 

Amendment dated October 25, 2005 

Amendment in response to Office Action dated July 12, 2005 

Amendments to Claims 

This listing of claims will replace all prior versions, and listings, of claims in the application: 

Listing of Clflltns: 

1. (currently amended) A processor comprising; 

instructions with at least one operand field, the instnictions comprises immediate instructions 
having i mmediat e data in the operand field; 

a data table for storing immediate data of imm B diate instmctioTi s / wherein immediate data are 
Stored in the data table in an order determined bv a flow analysis, the data table enables immediate 
data to be separated from the instruction stream; 

a program coimter for storing an instruction address of an instruction, wherein the processor 
fetches the an instruction from the instruction address in the program counter during program 
execution; and 

an instruction decoder for decoding the instruction fetched by the processor, wherein an 
immediate data from the data table is provided to the processor if the instruction fetched is an 
immediate instruction. 

2. * (original) The processor of claim 1 furtlier comprises an instruction register 
coupled to the instruction decoder, die instruction register stores the instruction fetched by the 
processor during program execution and passes the instruction to the mstmction decoder for decoding. 

3. (original) The processor of claim 2 wherein the instruction register is coupled to 
the data table, the instmction register provides an address of the immediate data in the data table when 
the immediate instruction is decoded by the instruction decoder. 
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4. (currently amended) The processor of claim 2 further comprises a data table addressing 
unit coupled to the instruction decoder and ^ data table, the data table addressing unit providing an 
address of the immediate data in the data table. 

5. (original) Tlie processor of claim 4 wherein the data table addressing unit 
comprises a data table pointer for storing the address- 

6. (currently amended) The processor of claim 4 wherein the instruction register is coupled to 
the data table addressing umX, the instruction register passes addressing information to the data table 
instruction addressing unit to provide the address when the immediate instruction is decoded by the 
instruction decoder. 

7. (original) The processor of claim 6 wherein the data table addressing unit 
comprises a data table pointer for storing the addressing information which serves as the address. 

S. (currently amended) The processor of claim 1 ftirther comprises a data table addressing 
unit coupled to the ijistruction decoder and the data table, the data addressing unit providing an 
address of the hnmediate data in die data tabic. 

9. (original) The processor of claim 8 wherein die data table addressing unit 
comprises a data table pointer for storing the address. 

1 0. (original) The processor of claim 8 fUrther comprises an instruction register 
coupled to the instruction decoder, the instruction register stores the instruction fetched by the 
processor during program execution and passes the instruction to the instruction decoder for decoding. 
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1 1 , (currently amended) The processor of claim 10 wherein the instruction register is coupled 
to the data table addressing xmit, the instruction register passes addressing information to the data table 
ingtructi^ aa addressing unit to provide the address when the immediate instruction is decoded by the 
instruction decoder, 

12 (original) Tlie processor of claim 1 1 wherein the data table addressing unit 

comprises a data table pointer for storing the addressing information which serves as the address. 

13. (original) The processor of claim 1 further comprises a data table addressing 
unit coupled to the instruction decoder and the data table, tfie data addressing unit provides an address 
of the immediate data in the data table when the instruction decoder decodes the immediate 
instruction, 

14. (original) The processor of claim 13 wherein tlie data table addressing unit 
comprises an incrementor, the incrementor increments the address after the immediate data is provided 
to produce a new address for a new immediate instruction, 

15. (original) The processor of claim 1 3 wherein the data tabfe addressing unit 
comprises: 

a data table pointer for storing the address; and 

an incrementor^ the incrementor increments the address in the data table pointer after the 
immediate data is provided to produce a new address in the data table pointer for a next inmiediate 
instruction executed by the processor. 
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1 6, (ciurently amended) The processor of claim 1 5 wherein the incrcmeator comprises an 
adder, the adder is coupled to the data table pointer, the adder adds the address in the table pointer and 
an index to produce the new address, 

1 7. (original) The processor of claim 16 wherein the uidex comprises a 1, 

IS. (currently amended) The processor of claim 13 wherein an addressing infonnation is 
passed to the data table addressing luiit, the addressing information comprises an index for indexing 
the address to produce a new address of another immediate data in the data table for another 
immediate instruction. 

19. (currently amended) The processor of claim 13 wherein addressing information is passed 
to the data table addressing unit, the addressing information comprises an index for indexing the 
address to produce a new address pointing to a next immediate data in the data table for a next 
immediate instruction fetched by the processor, 

20. (currendy amended) The processor of claim 18 49 further comprises an instruction register 
coupled to the instruction decoder and the data table addressing unit, the instruction register stores the 
instruction fetched by the processor during program execution and passes the instruction to the 
instruction decoder for decoding, when the decoder decodes the immediate instruction, the ii)Struction 
register passes the addressing information contained in the instruction to the data table addressing unit, 

2 1 . (original) The processor of claim 20 wherein the data table addressing unit 
comprises: 

a data table pointer for storing the address; and 
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an adder for adding the addressing information to the address after the ijBmediate data is 
provided to produce a new address in the data table pointer for a next immediate instruction executed 
by the processor. 

22. (currently amended) The processor of claim 1 further comprises: 

an instruction register coupled to the instniciion decoder, the instruction register stores the 
instruction fetched by the processor during program execution and passes the instruction to the 
instruction decoder for decoding; and 

a data table addressing unit coupled to the data table and the instruction register^ the 
instruction register passing relative addressing information contained in the instruction to the data 
table addressing unit when the decoder decodes the immediate instruction, the relative addressing 
infonnation, which comprises an index and a format indicator, is used to provide an address of the 
immediate data in the data table. 

23. (original) The processor of claim 22 wherein the data addressing unit comprises 
a data table pointer containing a value, 

if the format indicator comprises a post-format, the value serves as the address and after the 
immediate data is provided to the processor, the index is added to the value to produce a new value in 
the data table pointer for a next immediate instruction, and 

if the format indicator comprises a pre-format, the index is added to the value to produce the 
address to the immediate data and the address is Incremented by 1 after the immediate data is provided 
to the processor to produce a new value in the data table pointer for the next hnmediate instruction. 

24. (currently amended) The processor of claim 23 wherein the format indicator cojnprises a 
binary bit having a logic I and logic 0 value, tiie logic 1 indicating ihe a pre-format and the logic 0 
indicating the post-format. 



PAGE 12f23«RCVD AT 10/2512005 1:13:01 AM [Eastern Daylight Time]' SVR:USPTO€FXRF-6/25* DN]S:2738300' CSID:6S 6846 2005* DURATION (mm'SS):06-26 



25/10 '05 TOE 13:12 FAX 65 6846 2005 



HORIZON IP 



81013 



AppHcationNo, 09/979,572 
Amendment dated October 25, 2005 

Amendment in re$pOTiSe to Office Action dated July 12. 2005 

25. (currently amended) The processor of claim 24 wherein the data table addressing unit 
. comprises: 

a Hrst adder comprising a first input coupled to the instructioTJ register for receiving the index 
offbot and a second input coupled to an output of the data table pointer for receiving the value 
contained therein; 

a second adder comprising a first input coupled to the instruction register for receiving the 
format indicator, a second input coupled to an output of the first adder, and an output coupled to the 
data table pointer; and 

a multiplexor comprising a first input coupled to an output of the data table pointer, a second 
input coupled to the output of the first adder, and a select input coupled to the inscruction register for 
receiving the format indicator to select an multiplexor output from the first and second multiplexor 
inputs, 

26. (currently amended) The processor of claim 1 wherein the flow analysis comprises da^a 
tabl e comprises immediat e data stored in on order determin e d by a static flow analysi s, the static flow 
analysis to id e ntify Identifies immediate instructions within a program, 

27. (original) The processor of cjajm 26 wherein an immediate instruction 
comprises addressing information to enable the processor to retrieve a corresponding immediate data 
to the immediate instruction. 

28. (original) The processor of claim 27 wherein the addressing information 
comprises absolute addressing information. 

29. (original) The processor of claim 27 wherein Ae addressing information 
comprises relative addressing infonnation. 



PaseSoflS 

PAGE * RCVD AT 1(V2 W 1:13:01 AM [Eastern Daylight Time]' SVR:USPTO{FXRF-6/25 ' DNIS:2738300 ' CSID:65 6846 2005' DURATION (min-ss):06-26 



25/10 '05 TUE 13:12 FAX 65 6S46 2005 



HORIZON IP 



@014 



Application No. 09/979^572 
Aznendinent dated October 25» 2005 

Amendment in response to OfQce Action dated July 12, 2005 

30. (currently amended) The processor of claim 29 further comprises data table addressing 
unit coupled to the data table, the data table addressing unit receives the relative addressing 
information and produces an address to th e coirespoitding to the inmicdiate data in the data table. 

3 1 . (original) A method of executing instructions in a processo r, th e method 
compris e s by separating immediate data of immediate instructions from an instruction stream 
comprisinfi: 

performing a flow analysis on a program having instructions which includes immediate 
instructions having immed iate data; 

identify ing immediate data from the progra m iaod 

storing the immediate data in a data table in an order determined bv the flow analysis . 

32. (currently amended) The method recited in claim 31 further wherein separating the 
imm e diate data from th e instruction str e am c omprises: 

fetching an instruction from a program; 

decoding the instruction to determine a type of instruction; and 
if the instruction comprises an immediate instruction, fetching an immediate data 
corresponding to the immediate instruction from a data table, 

33. (ciurently amended) The method recited in claim 32 wherein the immediate data of the 
immediate instructions are stored in the data table in an order determined by ^ a flow analysis for 
identifying the immediate instructions In a program. 

34. (original) Th e method of claim 32 or 33 further comprises providing addressing 
Information for fetching the immediate data from the data table. 
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35. (original) The method of claim 34 wherein the inunediate instniction provides 

the addressing information. 

3 6, (original) The method of claim 3 5 further comprises storing the addressing 

information in a data table pointer. 

37. (original) The method of claim 35 wherein the addressing information 
comprises relative addressing information. 

38. (originaO The method of claim 37 further comprises processing the relative 
addressing information by a data table addressing unit to generate an address for fetching the 
immediate data from the data table. 

39. (currently amended) Themethodof claim 38 wherein processing the relative addressing 
information comprises: 

using a value stored in a data pointer of the data table addressing unit to serve as the address; 

and 

after fetching tlie immediate data, adding the relative addressing information to the value to 
produce a next address in the data table for fetching a next immediate data for a next immediate 
instruction. 

40. (original) The method of claim 38 wherein the addressing information 
comprises an index and a format indicator. 

41. (original) The method of claim 40 wherein processing the relative addressing 
information comprises: 
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if the format indicate comprises a post-format, 

using a value stored in a data pointer of the data addressing unit to serve as the 
address, and 

after fetching the hnmediate data, adding the index to the address to produce a next 
address in the data table for fetching a next immediate data for a next immediate 
instruction; and 
if the format indicator comprises a pre-format, 

adding the index to the value to serve as the address for fetching the immediate data in 
the data table, and 

incrementing the address after the immediate data is fetched to produce a next address 
in the data table for fetching a next immediate data for a next inmiediate instruction. 

42. (original) The method of claim 34 wherein the addressing information 
comprises relative addressing information* 

43. (original) The method of claim 42 wherein providing the relative addressing 
information comprises: 

using a value in a data pointer to provide the addressing information to fetch the immediate 
data firom the data table; and 

incrementing the value to provide a new addressing information for fetching another 
immediate data for a subsequent immediate instruction fetched by the processor, 

44-74. (cancelled) 

75. (new) A processor comprising: 

a data table for storing immediate data of immediate instructions; 
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a program counter for storing an instruction address of an instruction, herein the processor 
fetches the instruction from the instruction address in the program counter d\iring program execution; 
and ^ 

an instruction decoder for decoding the instruction fetched by the processor^ wherein 
immediate data from the data table is provided to the processor if the instruction is an immediate 
instruction; 

an instruction register coupled to the instruction decoder, the instruction register stores the 
instruction fetched by the processor during program execution and passes the instruction to the 
instruction decoder for decoding; 

a data table addressing unit comprising a data table pointer containing a value, the data table is 
coupled to the data table and instruction register, the mstruction register passing relative addressing 
information contained in die instruction to the data table addressing unit when the decoder decodes the 
immediate instruction, the relative addressing information, which comprises an index and a format 
indicator, is used to provide an address of the immediate data in the data table, wherein the format 
indicator comprises a binary bit having a logic I and logic 0 value, the logic i indicating one of a pre- 
format or a post-format and the logic 0 indicating other of the pre-format or post-format; 

if the format indicator indicates the post-format, the value serves as the address and after the 
immediate data is provided to the processor, the index is added to the value to produce a new value in 
the data table pointer for a next inunediate instruction and if the format indicator indicates the pre- 
format, the index is added to the value to produce the address to the immediate data and the address is 
incremented by 1 after the immediate data is provided to the processor to produce a new value in the 
data table pointer for the next immediate instruction; and 

wherein the addressing unit comprises 

a first adder comprising a first input coupled to the instruction register for receiving 

the index and a second input coupled to an output of the data table pointer for receiving the 

value contained therein. 
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a second adder comprising a first input coupled to the instruction register for receiving 
the format indicator, a second input coupled to an output of the first adder^ and an output 
coupled to the data table pointer, and 

a multiplexor comprising a first input coupled to an output of the data table pointer, a 
second input coupled to the output of the first adder, and a select input coupled to the 
instruction register for receiving the format indicator to select an multiplexor output from the 
first and second multiplexor inputs, 

76. (new) A processor comprising: 

a data table for storing immediate data of immediate instructions; 

a program counter for storing an instruction address of an instruction, wherein the processor 
fetches the instruction from the instruction address in the program counter during prograni execution; 
and 

an instruction decoder for decoding the instruction fetched by the processor, wherein 
immcdiiite data from the data tabic is provided to the processor if the instruction is an immediate 
instruction; 

an instruction register coupled to the instruction decoder, the instruction register stores the 
instruction fetched by the processor during program execution and passes the instruction to the 
instruction decoder for decoding; 

a data table addressing unit comprising a data table pointer having a value, the data table 
addressing unit receives relative addressing information for decoded immediate instructions, the 
relative addressing information, which comprises an index and a format indicator, is used to provide 
an address of the immediate data in the data table; 

if the format indicator indicates a post-format, the value serves as the address and after the 
immediate data is provided to the processor^ the index is added to the value to produce a new value in 
the data table pointer for a next immediate instruction ami if the fbnnat indicator indicates a pre- 
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format, the index is added to the value to produce tlie address to the immediate data and the address is 
incremented by 1 after the immediate data is provided to the processor to produce a new value in the 
data table pointer for the next immediate instruction; and 
wherein the addressing unit comprises 

a first adder comprising a first input coupled to the instruction register for receiving 
the offset and a second input coupled to an output of the data table pointer for receiving the 
value contained tiierein, 

a second adder comprising a first input coupled to the instruction register for receiving 
the format indicator, a second input coupled to an output of the first adder, and an output 
coupled to the data table pointer, and 

a multiplexor comprising a first input coupled to an output of the data table pointer, a 
second input coupled to the output of the first adder, and a select input coupled to the 
instruction register for receiving the format indicator to select an multiplexor output fix}m the 
first and second multiplexor inputs. 
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